inspector: Make the css tree respect inspected display
authorMatthias Clasen <mclasen@redhat.com>
Sat, 7 Dec 2019 17:42:37 +0000 (12:42 -0500)
committerMatthias Clasen <mclasen@redhat.com>
Sat, 7 Dec 2019 23:07:44 +0000 (18:07 -0500)
The display is used here to force reparsing the theme
on the right settings object.

gtk/inspector/css-node-tree.c
gtk/inspector/css-node-tree.h
gtk/inspector/init.c
gtk/inspector/window.c

index a95bb84092a09359609d2df586a679dc2f086541..11741e7c794268f2f2a42857bf2c5fa206cf42bc 100644 (file)
@@ -24,6 +24,7 @@
 
 #include "css-node-tree.h"
 #include "prop-editor.h"
+#include "window.h"
 
 #include "gtktreemodelcssnode.h"
 #include "gtktreeview.h"
@@ -221,28 +222,12 @@ gtk_inspector_css_node_tree_finalize (GObject *object)
   G_OBJECT_CLASS (gtk_inspector_css_node_tree_parent_class)->finalize (object);
 }
 
-static void
-ensure_css_sections (void)
-{
-  GtkSettings *settings;
-  gchar *theme_name;
-
-  gtk_css_provider_set_keep_css_sections ();
-
-  settings = gtk_settings_get_default ();
-  g_object_get (settings, "gtk-theme-name", &theme_name, NULL);
-  g_object_set (settings, "gtk-theme-name", theme_name, NULL);
-  g_free (theme_name);
-}
-
 static void
 gtk_inspector_css_node_tree_class_init (GtkInspectorCssNodeTreeClass *klass)
 {
   GObjectClass *object_class = G_OBJECT_CLASS (klass);
   GtkWidgetClass *widget_class = GTK_WIDGET_CLASS (klass);
 
-  ensure_css_sections ();
-
   object_class->set_property = gtk_inspector_css_node_tree_set_property;
   object_class->get_property = gtk_inspector_css_node_tree_get_property;
   object_class->finalize = gtk_inspector_css_node_tree_finalize;
@@ -531,4 +516,17 @@ gtk_inspector_css_node_tree_get_node (GtkInspectorCssNodeTree *cnt)
   return priv->node;
 }
 
+void
+gtk_inspector_css_node_tree_set_display (GtkInspectorCssNodeTree *cnt,
+                                         GdkDisplay *display)
+{
+  GtkSettings *settings;
+  gchar *theme_name;
+
+  settings = gtk_settings_get_for_display (display);
+  g_object_get (settings, "gtk-theme-name", &theme_name, NULL);
+  g_object_set (settings, "gtk-theme-name", theme_name, NULL);
+  g_free (theme_name);
+}
+
 // vim: set et sw=2 ts=2:
index e1357a7dcb2080df1e113b8fde8bb84e500eedb5..881e433ce125d7ed263456b24319f3f2e03ad99b 100644 (file)
@@ -55,6 +55,9 @@ void            gtk_inspector_css_node_tree_set_object          (GtkInspectorCss
                                                                  GObject                        *object);
 
 GtkCssNode *    gtk_inspector_css_node_tree_get_node            (GtkInspectorCssNodeTree        *cnt);
+void            gtk_inspector_css_node_tree_set_display         (GtkInspectorCssNodeTree        *cnt,
+                                                                 GdkDisplay                     *display);
+
 
 G_END_DECLS
 
index 6c9230fca572dcedf39b052a0ae3620d107c34e1..2681e62e8128a83a24296c8cff42bebd71705860 100644 (file)
@@ -46,6 +46,7 @@
 #include "window.h"
 
 #include "gtkmagnifierprivate.h"
+#include "gtkcssproviderprivate.h"
 
 #include "gtkmodulesprivate.h"
 
@@ -96,6 +97,8 @@ gtk_inspector_init (void)
       g_strfreev (paths);
       g_io_module_scope_free (scope);
     }
+
+  gtk_css_provider_set_keep_css_sections ();
 }
 
 // vim: set et sw=2 ts=2:
index 2a805079772431e926ca2d6403f4f3f88adf9ade..2d82629124cc6e45e8c61b83d26efd0dc96457b1 100644 (file)
@@ -274,6 +274,7 @@ gtk_inspector_window_constructed (GObject *object)
   gtk_inspector_visual_set_display (GTK_INSPECTOR_VISUAL (iw->visual), iw->inspected_display);
   gtk_inspector_general_set_display (GTK_INSPECTOR_GENERAL (iw->general), iw->inspected_display);
   gtk_inspector_logs_set_display (GTK_INSPECTOR_LOGS (iw->logs), iw->inspected_display);
+  gtk_inspector_css_node_tree_set_display (GTK_INSPECTOR_CSS_NODE_TREE (iw->widget_css_node_tree), iw->inspected_display);
 }
 
 static void